import uniqueId from '@form-create/utils/lib/unique'
import { localeProps } from '../utils'

export const useUploadFileRule = () => {
  const label = '文件上传'
  const name = 'UploadFile'
  return {
    icon: 'icon-upload', // 复用已有icon
    label,
    name,
    rule() {
      // 定义组件的渲染规则，对应该组件在form create中的rule，组件拖拽出来的初始规则值，后续通过下面配置的props构成的右侧配置表单项目，进行该rule的props的变更
      return {
        type: name,
        field: uniqueId(),
        title: label,
        info: '',
        $required: false,
        props: {}
      }
    },
    props(_, { t }) {
      // 配置UploadFile的props属性值
      // 构建该组件的右侧配置项目，使用form create的rule定制动态表单
      // localeProps将rule的title转为国际化，若有必要
      return localeProps(t, name + '.props', [
        // makeRequiredRule(), // 是否必填
        {
          type: 'select',
          field: 'fileType',
          title: '文件类型',
          value: ['doc', 'docx', 'xls', 'xlsx', 'ppt', 'txt', 'pdf'],
          options: [
            { label: 'doc', value: 'doc' },
            { label: 'docx', value: 'docx' },
            { label: 'xls', value: 'xls' },
            { label: 'xlsx', value: 'xlsx' },
            { label: 'ppt', value: 'ppt' },
            { label: 'txt', value: 'txt' },
            { label: 'pdf', value: 'pdf' }
          ],
          props: {
            multiple: true // 配置select组件的multiple=true，支持多选
          }
        },
        {
          type: 'inputNumber',
          field: 'fileSize',
          title: '大小限制(MB)',
          value: 5,
          props: { min: 0 }
        },
        {
          type: 'inputNumber',
          field: 'limit',
          title: '数量限制',
          value: 5,
          props: { min: 0 }
        },
        {
          type: 'switch',
          field: 'autoUpload',
          title: '是否在选取文件后立即进行上传',
          value: true
        },
        {
          type: 'switch',
          field: 'drag',
          title: '是否支持拖拽上传',
          value: false
        },
        {
          type: 'switch',
          field: 'isShowTip',
          title: '是否显示提示',
          value: true
        },
        {
          type: 'switch',
          field: 'disabled',
          title: '是否禁用',
          value: false
        }
      ])
    }
  }
}
